This is Kara’s first pass at looking at the Sleep data (with data from 2019-01-24).
Demographics
A couple of things to note here: A substantial majority of participants in Thailand were female, and this also appears to be true in China and Vanuatu (where an unusual number of participants are missing gender/sex info).
Questions 1-23
1. Where do you usually sleep at night? (slep_ordn01)

2. What do you usually sleep on at night? (slep_ordn02)

3. Does anyone else sleep in the same bed (or mat, hammock, etc.) with you? (slep_ordn03)

4. If yes, who sleeps with you in the bed? Please circle the person(s) from the list (slep_ordn04)

5. Besides anyone who shares the bed with you, does someone else sleep in the same room with you? (slep_ordn05)

6. If yes, who else sleeps in the same room with you? Please circle the person(s) from the list (slep_ordn06)

7. What does your family use to see at night? (slep_ordn07)

8. Do you usually take naps? (slep_ordn08)

9. If so, how often do you rest or nap? (slep_ordn09)


10. When do you typically fall asleep every night and wake up every night? (slep_ordn10)



11. Does that vary a lot from night to night? (slep_ordn11)


12a. RA judgment for hours slept (slep_ordn12a, derived from slep_ordn12)

13. What do you think is the most important role of sleep for you? (slep_ordn13)

14. Do you look forward to dreaming? (slep_ordn14)


15. Are dreams an important source of spiritual insight for you? (slep_ordn15)


16. Do you regard sleep as a doorway into another way of being? (slep_ordn16)

17. Do special spiritual things happen during the night for you? (slep_ordn17)


18. Do you wake up to pray in the middle of the night? (slep_ordn18)


19a. RA judgment for time spent in prayer (slep_ordn19a, derived from slep_ordn19)

20. If you do, do you go back to sleep? (slep_ordn20)


21. Do you intentionally sleep in any specific positions that have spiritual or health consequences? (slep_ordn21)


22. Do you interact with God or with spirits in the middle of the night? (slep_ordn22)


23. What wakes you up most at night? (slep_ordn23)

“Edge” survey
Total score (slep_edge_total)


Individual questions
The “edge” survey consisted of 20 questions, labeled as follows (order may have varied across versions?):
slep_edge01: 11. I’ve felt an evil presence in the room, but could not see, hear, touch or smell anyone there.
slep_edge02: 12. I’ve heard someone calling my name
slep_edge03: 13. I’ve seen a blurry human figure in the room.
slep_edge04: 14.I’ve had the sense of an invisible presence watching me.
slep_edge05: 15. I’ve heard the voice of a person I could not identify.
slep_edge06: 16. I’ve heard human speech which spoke in a garbled, unclear way.
slep_edge07: 17. I’ve seen the image of a face.
slep_edge08: 18. I’ve heard the voice of someone familiar to me.
slep_edge09: 19. I’ve see things or figures floating in my room.
slep_edge10: 20. I’ve felt the presence of an intruder in my bedroom, though I did not actually see, hear, touch or smell anyone
slep_edge11: 1. I’ve clearly seen people in my room
slep_edge12: 2. I’ve heard non-speech sound, such as laughter, music or other noises
slep_edge13: 3. I’ve seen things in my room other than people
slep_edge14: 4. I’ve had the feeling of a presence in the room which I felt was aware of me too, but I could not actually see, hear, touch or smell them
slep_edge15: 5. I’ve heard God (or a spirit) speak
slep_edge16: 6. I’ve heard God (or a spirit) singing to me.
slep_edge17: 7. I’ve seen an angel (or a spirit)
slep_edge18: 8. I’ve seen a ghost
slep_edge19: 9. I’ve felt the presence of God (or a spirit)
slep_edge20: 10. I have woken up and been unable to move.
attributes are not identical across measure variables;
they will be dropped

attributes are not identical across measure variables;
they will be dropped

---
title: "Sleep (KW first pass)"
subtitle: "Last updated: 2019-01-25"
output:
  html_notebook:
    toc: yes
    toc_depth: 4
    toc_float: yes
always_allow_html: yes
---

This is Kara's first pass at looking at the Sleep data (with data from 2019-01-24).

```{r global_options, include = F}
knitr::opts_chunk$set(fig.width = 4, fig.asp = 0.67,
                      include = F, echo = F)
```

```{r}
library(tidyverse)
library(langcog)
library(psych)
library(readxl)
library(cowplot)
library(lme4)
library(lmerTest)
library(kableExtra)
library(lubridate)

theme_set(theme_bw())
```

```{r}
d_raw <- read_csv("../COMPLETE_use for analysis_Sleep_Jan.24.2019.csv")
```

```{r}
d0 <- d_raw %>%
  mutate_at(vars(slep_ordn11, slep_ordn12a, slep_ordn19a, slep_edge_total, 
                 slep_demo_age, slep_demo_ses, slep_demo_howr), 
            funs(as.numeric)) %>%
  mutate_at(vars(slep_ordn03, slep_ordn05, slep_ordn08, slep_ordn16),
            funs(recode_factor(., "0" = "no", "1" = "yes"))) %>%
  mutate_at(vars(slep_ordn04, slep_ordn06),
            funs(recode_factor(., "0" = "nobody", "1" = "spouse", "2" = "sister", 
                               "3" = "brother", "4" = "daughter", "5" = "son",
                               "6" = "mother", "7" = "father", "8" = "grandparent", 
                               "9" = "grandchild", "10" = "other relative", 
                               "11" = "non-relative"))) %>%
  mutate_at(vars(slep_ordn11_worldofspirits, slep_ordn13_deepself,
                 slep_ordn13_mindoff, slep_ordn13_replenish,
                 slep_ordn23_Physiological, slep_ordn23_Psychological,
                 slep_ordn23_Dreams, slep_ordn23_Sound,
                 slep_ordn23_supernaturalprayer),
            funs(factor(.,
                        levels = c("\\.", "1"),
                        labels = c("no", "yes")))) %>%
  mutate_at(vars(slep_ordn15, slep_ordn17, slep_ordn18, slep_ordn20:slep_ordn22),
            funs(recode_factor(., "0" = "never", "1" = "rarely", 
                               "2" = "sometimes", "3" = "often"))) %>%
  mutate_at(vars(starts_with("slep_edge"), -slep_edge_total),
            funs(recode_factor(., "0" = "never", "1" = "rarely", 
                               "2" = "occasionally", "3" = "frequently"))) %>%
  mutate(slep_ordn01 = recode_factor(slep_ordn01, 
                                     "1" = "own bedroom", 
                                     "2" = "bedroom shared with others",
                                     "3" = "common room (living plus sleeping)",
                                     "4" = "porch/outside",
                                     "5" = "not in home",
                                     "6" = "variable"),
         slep_ordn02 = recode_factor(slep_ordn02,
                                     "1" = "bed", "2" = "sofa, divan", 
                                     "3" = "mat, ground", "4" = "hammock"),
         slep_ordn07 = recode_factor(slep_ordn07,
                                     "0" = "nothing, just the moon and stars",
                                     "1" = "light from the cooking fire or hearth",
                                     "2" = "candles or straw torches", 
                                     "3" = "oil or kerosene lamp",
                                     "4" = "battery-driven lamp or flashlight", 
                                     "5" = "electric light"),
         slep_ordn09 = recode_factor(slep_ordn09,
                                     "0" = "NA (never)", "1" = "rarely",
                                     "2" = "sometimes (1-2 times a week)", 
                                     "3" = "usually but not everyday (3-6 times a week)", 
                                     "4" = "every day"),
         slep_ordn14 = recode_factor(slep_ordn14,
                                     "0" = "no", "1" = "a little", "2" = "a lot"),
         slep_ctry = recode_factor(slep_ctry, "1" = "US", "4" = "Ghana", 
                                   "3" = "Thailand", "2" = "China", 
                                   "5" = "Vanuatu"),
         slep_demo_sex = recode_factor(slep_demo_sex, "1" = "m", "2" = "f"),
         slep_demo_ubru = recode_factor(slep_demo_ubru, "1" = "urban", "2" = "rural"),
         slep_demo_affr = recode_factor(slep_demo_affr, "1" = "no", "0" = "yes"),
         slep_demo_tung = recode_factor(slep_demo_tung, "0" = "no", "1" = "yes")) %>%
  select(-c(slep_entr:slep_batc, slep_file:slep_whoc)) %>%
  distinct()
```

```{r}
# deal with sleeping & waking times
# not quite perfect!!
d1 <- d0 %>%
  mutate_at(vars(`slep_ordn10a#1_1_1`, `slep_ordn10a#1_2_1`),
            funs(gsub("^0\\:", "12\\:", .))) %>%
  mutate(slep_datesleep = ifelse(`slep_ordn10a#2_1` == "PM", 
                                 as.character(today()), as.character(today() + 1)),
         slep_datewake = as.character(today() + 1),
         slep_datetimesleep = paste(slep_datesleep, 
                                    `slep_ordn10a#1_1_1`, `slep_ordn10a#2_1`),
         slep_datetimewake = paste(slep_datewake,
                                   `slep_ordn10a#1_2_1`, `slep_ordn10a#2_2`)) %>%
  mutate_at(vars(slep_datetimesleep, slep_datetimewake),
            funs(ifelse(grepl("MD", .), NA, .))) %>%
  mutate_at(vars(slep_datetimesleep, slep_datetimewake),
            funs(parse_datetime(., format = "%Y-%m-%d %I:%M %p"))) %>%
  mutate(slep_interval = interval(slep_datetimesleep, slep_datetimewake),
         slep_duration = as.duration(slep_interval),
         slep_duration_num = as.numeric(slep_duration, "hours"))
```

```{r}
d <- d1
```

```{r}
# check country codes
d %>% 
  distinct(slep_ctry, slep_subj) %>%
  mutate(slep_subj_firstdig = substr(slep_subj, 1, 1)) %>%
  count(slep_ctry, slep_subj_firstdig)
```



# Demographics

```{r, include = T}
d %>%
  distinct(slep_ctry, slep_subj) %>%
  count(slep_ctry)
```

```{r, include = T}
d %>%
  distinct(slep_ctry, slep_subj, slep_demo_sex) %>%
  group_by(slep_ctry) %>%
  count(slep_demo_sex) %>%
  mutate(prop = round(n/sum(n), 2)) %>%
  ungroup() %>%
  select(-n) %>%
  spread(slep_demo_sex, prop)
```

A couple of things to note here: A substantial majority of participants in Thailand were female, and this also appears to be true in China and Vanuatu (where an unusual number of participants are missing gender/sex info).

```{r, include = T}
d0 %>%
  distinct(slep_ctry, slep_subj, slep_demo_age) %>%
  group_by(slep_ctry) %>%
  summarise(median = median(slep_demo_age, na.rm = T),
            mean = mean(slep_demo_age, na.rm = T),
            sd = sd(slep_demo_age, na.rm = T),
            min = min(slep_demo_age, na.rm = T),
            max = max(slep_demo_age, na.rm = T)) %>%
  mutate_at(vars(median, mean, sd, min, max), funs(round(., 2)))
```


<P style="page-break-before: always">
# Questions 1-23

## 1. Where do you usually sleep at night? (`slep_ordn01`)

```{r, fig.width = 4, include = T}
d %>%
  mutate(slep_ordn01 = case_when(grepl(",", slep_ordn01) ~ 
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn01)),
         slep_ordn01 = factor(slep_ordn01,
                              levels = c("own bedroom", 
                                         "bedroom shared with others", 
                                         "common room (living plus sleeping)", 
                                         "porch/outside", "not in home", 
                                         "variable", 
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn01) %>%
  complete(slep_ordn01, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn01, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "1. Where do you usually sleep at night? (`slep_ordn01`)", 
       x = "Response", y = "Proportion of participants")
```


## 2. What do you usually sleep on at night? (`slep_ordn02`)

```{r, fig.width = 4, include = T}
d %>%
  mutate(slep_ordn02 = case_when(grepl(",", slep_ordn02) ~ 
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn02)),
         slep_ordn02 = factor(slep_ordn02,
                              levels = c("bed", 
                                         "sofa, divan", 
                                         "mat, ground", 
                                         "hammock", 
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn02) %>%
  complete(slep_ordn02, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn02, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "2. What do you usually sleep on at night? (`slep_ordn02`)", 
       x = "Response", y = "Proportion of participants")
```


## 3. Does anyone else sleep in the same bed (or mat, hammock, etc.) with you? (`slep_ordn03`)

```{r, fig.width = 4, include = T}
d %>%
  mutate(slep_ordn03 = case_when(grepl(",", slep_ordn03) ~
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn03)),
         slep_ordn03 = factor(slep_ordn03,
                              levels = c("yes", "no",
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn03) %>%
  complete(slep_ordn03, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn03, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "3. Does anyone else sleep in the same bed (or mat, hammock, etc.) with you?\n(`slep_ordn03`)", 
       x = "Response", y = "Proportion of participants")
```


## 4. If yes, who sleeps with you in the bed? Please circle the person(s) from the list (`slep_ordn04`)

```{r, fig.width = 5, fig.asp = 0.5, include = T}
d %>%
  mutate(slep_ordn04 = case_when(grepl(",", slep_ordn04) ~
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn04)),
         slep_ordn04 = factor(slep_ordn04,
                              levels = c("nobody", "spouse", "sister", "brother",
                                         "daughter", "son", "mother", "father",
                                         "grandparent", "grandchild", 
                                         "other relative", "non-relative",
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn04) %>%
  complete(slep_ordn04, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn04, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "4. If yes, who sleeps with you in the bed? Please circle the person(s) from the list (`slep_ordn04`)", 
       x = "Response", y = "Proportion of participants")
```


## 5. Besides anyone who shares the bed with you, does someone else sleep in the same room with you? (`slep_ordn05`)

```{r, fig.width = 4, include = T}
d %>%
  mutate(slep_ordn05 = case_when(grepl(",", slep_ordn05) ~ 
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn05)),
         slep_ordn05 = factor(slep_ordn05,
                              levels = c("no", "yes", 
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn05) %>%
  complete(slep_ordn05, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn05, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "5. Besides anyone who shares the bed with you, does someone else sleep in the same\nroom with you? (`slep_ordn05`)", 
       x = "Response", y = "Proportion of participants")
```


## 6. If yes, who else sleeps in the same room with you? Please circle the person(s) from the list (`slep_ordn06`)

```{r, fig.width = 5, fig.asp = 0.5, include = T}
d %>%
  mutate(slep_ordn06 = case_when(grepl(",", slep_ordn06) ~
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn06)),
         slep_ordn06 = factor(slep_ordn06,
                              levels = c("nobody", "spouse", "sister", "brother",
                                         "daughter", "son", "mother", "father",
                                         "grandparent", "grandchild", 
                                         "other relative", "non-relative",
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn06) %>%
  complete(slep_ordn06, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn06, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "6. If yes, who else sleeps in the same room with you? Please circle the person(s) from the list (`slep_ordn06`)", 
       x = "Response", y = "Proportion of participants")
```


## 7. What does your family use to see at night? (`slep_ordn07`)

```{r, fig.width = 5, fig.asp = 0.5, include = T}
d %>%
  mutate(slep_ordn07 = case_when(grepl(",", slep_ordn07) ~ 
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn07)),
         slep_ordn07 = factor(slep_ordn07,
                              levels = c("nothing, just the moon and stars",
                                         "light from the cooking fire or hearth",
                                         "candles or straw torches",
                                         "oil or kerosene lamp", 
                                         "battery-driven lamp or flashlight", 
                                         "electric light", 
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn07) %>%
  complete(slep_ordn07, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn07, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "7. What does your family use to see at night? (`slep_ordn07`)", 
       x = "Response", y = "Proportion of participants")
```


## 8. Do you usually take naps? (`slep_ordn08`)

```{r, fig.width = 4, include = T}
d %>%
  mutate(slep_ordn08 = case_when(grepl(",", slep_ordn08) ~ 
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn08)),
         slep_ordn08 = factor(slep_ordn08,
                              levels = c("no", "yes", 
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn08) %>%
  complete(slep_ordn08, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn08, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "8. Do you usually take naps? (`slep_ordn08`)", 
       x = "Response", y = "Proportion of participants")
```


## 9. If so, how often do you rest or nap? (`slep_ordn09`)

```{r, fig.width = 4, include = T}
d %>%
  mutate(slep_ordn09 = case_when(grepl(",", slep_ordn09) ~ 
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn09)),
         slep_ordn09 = factor(slep_ordn09,
                              levels = c("NA (never)", "rarely",
                                         "sometimes (1-2 times a week)",
                                         "usually but not everyday (3-6 times a week)",
                                         "every day",
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn09) %>%
  complete(slep_ordn09, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn09, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "9. If so, how often do you rest or nap? (`slep_ordn09`)", 
       x = "Response", y = "Proportion of participants")
```

```{r, fig.width = 4, include = T}
d %>%
  distinct(slep_subj, slep_ctry, slep_ordn09) %>%
  filter(slep_ordn09 != ".") %>%
  ggplot(aes(x = slep_ctry, y = slep_ordn09, color = slep_ctry)) +
  geom_jitter(alpha = 0.25, width = 0.25, height = 0.25) +
  geom_pointrange(data = . %>% 
                    group_by(slep_ctry) %>%
                    mutate(slep_ordn09 = as.numeric(slep_ordn09)) %>%
                    multi_boot_standard(col = "slep_ordn09") %>%
                    ungroup(),
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper), 
                  color = "black") +
  scale_color_brewer(palette = "Dark2", guide = "none") +
  # theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "9. If so, how often do you rest or nap? (`slep_ordn09`)",
       subtitle = "Error bars are 95% bootstrapped confidence intervals",
       x = "Site", y = "Response")
```

## 10. When do you typically fall asleep every night and wake up every night? (`slep_ordn10`)

```{r, fig.width = 5, include = T}
d %>%
  distinct(slep_ctry, slep_subj, slep_datetimesleep, slep_datetimewake) %>%
  mutate_at(vars(slep_datetimesleep, slep_datetimewake),
            funs(as.character)) %>%
  gather(sleepwake, time, -c(slep_ctry, slep_subj)) %>%
  mutate(time = parse_datetime(time),
         sleepwake = factor(sleepwake,
                            levels = c("slep_datetimesleep", "slep_datetimewake"),
                            labels = c("fall asleep", "wake up"))) %>%
  ggplot(aes(x = time, fill = slep_ctry, color = sleepwake)) +
  facet_wrap(~ slep_ctry, ncol = 3) +
  geom_density(position = "identity", alpha = 0.5, size = 0.8) +
  geom_vline(xintercept = paste(today() + 1, "12:00 AM") %>% 
               as_datetime(format = "%Y-%m-%d %I:%M %p"), 
             color = "darkblue", lty = 2) +
  geom_vline(xintercept = paste(today() + 1, "08:00 AM") %>% 
               as_datetime(format = "%Y-%m-%d %I:%M %p"), 
             color = "darkred", lty = 2) +
  # annotate("text",
  #          x = paste(today() + 1, "1:00 AM") %>%
  #            as_datetime(format = "%Y-%m-%d %I:%M %p"),
  #          y = 0.00015, label = "← midnight", hjust = 0) +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  scale_color_manual(values = c("darkblue", "darkred"), guide = "none") +
  scale_x_datetime(date_breaks = "6 hours", date_minor_breaks =  "2 hours", 
                   date_labels = "%I:%m %p") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1),
        legend.position = "top") +
  labs(title = "10. When do you typically fall asleep every night and wake up every night? (`slep_ordn10`)", 
       subtitle = "NOTE: Lots of missing data here!\nDotted lines indicate 12:00 AM (midnight) and 8:00AM; blue outline indicates time to fall asleep, and red indicates time to wake up",
       x = "Response", y = "Density (~proportion of participants)", 
       color = "Sleep vs. wake")
```

```{r, fig.width = 5, include = T}
d %>%
  ggplot(aes(x = slep_duration_num, fill = slep_ctry)) +
  facet_wrap(~ slep_ctry, ncol = 3) +
  geom_density(position = "identity", alpha = 0.5, size = 0.8) +
  geom_vline(xintercept = 8, lty = 2) +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1),
        legend.position = "top") +
  labs(title = "Length of sleep (derived from `slep_ordn10`)", 
       subtitle = "NOTE: Lots of missing data here!\nDotted line indicates 8 hours",
       x = "Length of sleep (hours)", y = "Density (~proportion of participants)")
```

```{r, fig.width = 4, fig.asp = 1, include = T}
d %>%
  distinct(slep_subj, slep_ctry, slep_duration_num) %>%
  filter(!is.na(slep_duration_num)) %>%
  ggplot(aes(x = slep_ctry, y = slep_duration_num, color = slep_ctry)) +
  geom_hline(yintercept = 8, lty = 2) +
  geom_jitter(alpha = 0.25, width = 0.25, height = 0.25) +
  geom_pointrange(data = . %>% 
                    group_by(slep_ctry) %>%
                    multi_boot_standard(col = "slep_duration_num") %>%
                    ungroup(),
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper), 
                  color = "black") +
  scale_color_brewer(palette = "Dark2", guide = "none") +
  scale_y_continuous(trans = "log1p", breaks = seq(0, 100, 4)) +
  # theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "Length of sleep (derived from `slep_ordn10`)",
       subtitle = "NOTE: Lots of missing data here!\nPlotted after applying log transformation to highlight differences between sites\nError bars are 95% bootstrapped confidence intervals;\nDotted line indicates 8 hours",
       x = "Site", y = "Length of sleep (hours)")
```


## 11. Does that vary a lot from night to night? (`slep_ordn11`)

```{r, fig.width = 4, include = T}
d %>%
  mutate(slep_ordn11 = case_when(grepl(",", slep_ordn11) ~ 
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn11)),
         slep_ordn11 = factor(slep_ordn11,
                              levels = c(1:5, "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn11) %>%
  complete(slep_ordn11, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn11, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "11. Does that vary a lot from night to night? For example, do you regularly sleep from one\ntime (maybe 10 pm) to another time (maybe 6 am) each night, or sometimes do you sleep\nat 10, other nights midnight, some days you get up at 2 am, sometimes and 5 am,\nsometimes 7 am, at very different times? (`slep_ordn11`)",
       subtitle = "1: No variation, 5: Very very varied",
       x = "Response", y = "Proportion of participants")
```

```{r, fig.width = 4, include = T}
d %>%
  distinct(slep_subj, slep_ctry, slep_ordn11) %>%
  filter(slep_ordn11 != ".") %>%
  ggplot(aes(x = slep_ctry, y = slep_ordn11, color = slep_ctry)) +
  geom_jitter(alpha = 0.25, width = 0.25, height = 0.25) +
  geom_pointrange(data = . %>% 
                    group_by(slep_ctry) %>%
                    mutate(slep_ordn11 = as.numeric(slep_ordn11)) %>%
                    multi_boot_standard(col = "slep_ordn11") %>%
                    ungroup(),
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper), 
                  color = "black") +
  scale_color_brewer(palette = "Dark2", guide = "none") +
  # theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "11. Does that vary a lot from night to night? For example, do you regularly sleep from one\ntime (maybe 10 pm) to another time (maybe 6 am) each night, or sometimes do you sleep\nat 10, other nights midnight, some days you get up at 2 am, sometimes and 5 am,\nsometimes 7 am, at very different times? (`slep_ordn11`)",
       subtitle = "Error bars are 95% bootstrapped confidence intervals",
       x = "Site", y = "Response (1: No variation, 5: Very very varied)")
```


## 12a. RA judgment for hours slept (`slep_ordn12a`, derived from `slep_ordn12`)

```{r, fig.width = 4, include = T}
d %>%
  distinct(slep_subj, slep_ctry, slep_ordn12a) %>%
  filter(slep_ordn12a != ".") %>%
  filter(slep_ordn12a <= 20) %>%
  ggplot(aes(x = slep_ctry, y = slep_ordn12a, color = slep_ctry)) +
  geom_hline(yintercept = 8, lty = 2) +
  geom_jitter(alpha = 0.25, width = 0.25, height = 0.25) +
  geom_pointrange(data = . %>% 
                    group_by(slep_ctry) %>%
                    mutate(slep_ordn12a = as.numeric(slep_ordn12a)) %>%
                    multi_boot_standard(col = "slep_ordn12a") %>%
                    ungroup(),
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper), 
                  color = "black") +
  scale_color_brewer(palette = "Dark2", guide = "none") +
  # theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "12a. RA judgment for hours slept (`slep_ordn12a`, derived from `slep_ordn12`)",
       subtitle = "NOTE: Excluded one outlier (1 participant in VT who was judged to sleep > 20 hours;\nError bars are 95% bootstrapped confidence intervals; dotted line indicates 8 hours",
       x = "Site", y = "Number of hours slept (RA judgment)")
```


## 13. What do you think is the most important role of sleep for you? (`slep_ordn13`)

```{r, fig.width = 4, include = T}
d %>%
  distinct(slep_ctry, slep_subj, slep_ordn11_worldofspirits,
           slep_ordn13_deepself, slep_ordn13_mindoff, slep_ordn13_replenish) %>%
  gather(role, response, -c(slep_ctry, slep_subj)) %>%
  mutate(role = recode_factor(role,
                              "slep_ordn13_replenish" = "replenish energy",
                              "slep_ordn13_mindoff" = "shut your mind off",
                              "slep_ordn13_deepself" = "gain access to your deepest self",
                              "slep_ordn11_worldofspirits" = "connect with a world of spirits"),
         response = case_when(is.na(response) ~ "not selected", TRUE ~ response),
         response = factor(response, levels = c("not selected", "yes"))) %>%
  ggplot(aes(x = role, fill = slep_ctry, alpha = response)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "count", position = "fill") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  scale_alpha_manual(values = c(0.1, 1), guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "13. What do you think is the most important role of sleep for you? (`slep_ordn13`)", 
       x = "Role", y = "Proportion of participants selecting 'yes'")
```


## 14. Do you look forward to dreaming? (`slep_ordn14`)

```{r, fig.width = 4, include = T}
d %>%
  mutate(slep_ordn14 = case_when(grepl(",", slep_ordn14) ~ 
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn14)),
         slep_ordn14 = factor(slep_ordn14,
                              levels = c("no", "a little", "a lot",
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn14) %>%
  complete(slep_ordn14, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn14, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "14. Do you look forward to dreaming? (`slep_ordn14`)",
       x = "Response", y = "Proportion of participants")
```

```{r, fig.width = 4, include = T}
d %>%
  distinct(slep_subj, slep_ctry, slep_ordn14) %>%
  filter(slep_ordn14 != ".") %>%
  ggplot(aes(x = slep_ctry, y = slep_ordn14, color = slep_ctry)) +
  geom_jitter(alpha = 0.25, width = 0.25, height = 0.25) +
  geom_pointrange(data = . %>% 
                    group_by(slep_ctry) %>%
                    mutate(slep_ordn14 = as.numeric(slep_ordn14)) %>%
                    multi_boot_standard(col = "slep_ordn14") %>%
                    ungroup(),
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper), 
                  color = "black") +
  scale_color_brewer(palette = "Dark2", guide = "none") +
  # theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "14. Do you look forward to dreaming? (`slep_ordn14`)",
       subtitle = "Error bars are 95% bootstrapped confidence intervals",
       x = "Site", y = "Response")
```


## 15. Are dreams an important source of spiritual insight for you? (`slep_ordn15`)

```{r, fig.width = 4, include = T}
d %>%
  mutate(slep_ordn15 = case_when(grepl(",", slep_ordn15) ~ 
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn15)),
         slep_ordn15 = factor(slep_ordn15,
                              levels = c("never", "rarely", "sometimes", "often",
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn15) %>%
  complete(slep_ordn15, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn15, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "15. Are dreams an important source of spiritual insight for you? (`slep_ordn15`)",
       x = "Response", y = "Proportion of participants")
```

```{r, fig.width = 4, include = T}
d %>%
  distinct(slep_subj, slep_ctry, slep_ordn15) %>%
  filter(slep_ordn15 != ".") %>%
  ggplot(aes(x = slep_ctry, y = slep_ordn15, color = slep_ctry)) +
  geom_jitter(alpha = 0.25, width = 0.25, height = 0.25) +
  geom_pointrange(data = . %>% 
                    group_by(slep_ctry) %>%
                    mutate(slep_ordn15 = as.numeric(slep_ordn15)) %>%
                    multi_boot_standard(col = "slep_ordn15") %>%
                    ungroup(),
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper), 
                  color = "black") +
  scale_color_brewer(palette = "Dark2", guide = "none") +
  # theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "15. Are dreams an important source of spiritual insight for you?",
       subtitle = "Error bars are 95% bootstrapped confidence intervals",
       x = "Site", y = "Response")
```


## 16. Do you regard sleep as a doorway into another way of being? (`slep_ordn16`)

```{r, fig.width = 4, include = T}
d %>%
  mutate(slep_ordn16 = case_when(grepl(",", slep_ordn16) ~ 
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn16)),
         slep_ordn16 = factor(slep_ordn16,
                              levels = c("no", "yes", 
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn16) %>%
  complete(slep_ordn16, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn16, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "16. Do you regard sleep as a doorway into another way of being? (`slep_ordn16`)", 
       x = "Response", y = "Proportion of participants")
```


## 17. Do special spiritual things happen during the night for you? (`slep_ordn17`)

```{r, fig.width = 4, include = T}
d %>%
  mutate(slep_ordn17 = case_when(grepl(",", slep_ordn17) ~ 
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn17)),
         slep_ordn17 = factor(slep_ordn17,
                              levels = c("never", "rarely", "sometimes", "often",
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn17) %>%
  complete(slep_ordn17, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn17, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "17. Do special spiritual things happen during the night for you? (`slep_ordn17`)",
       x = "Response", y = "Proportion of participants")
```

```{r, fig.width = 4, include = T}
d %>%
  distinct(slep_subj, slep_ctry, slep_ordn17) %>%
  filter(slep_ordn17 != ".") %>%
  ggplot(aes(x = slep_ctry, y = slep_ordn17, color = slep_ctry)) +
  geom_jitter(alpha = 0.25, width = 0.25, height = 0.25) +
  geom_pointrange(data = . %>% 
                    group_by(slep_ctry) %>%
                    mutate(slep_ordn17 = as.numeric(slep_ordn17)) %>%
                    multi_boot_standard(col = "slep_ordn17") %>%
                    ungroup(),
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper), 
                  color = "black") +
  scale_color_brewer(palette = "Dark2", guide = "none") +
  # theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "17. Do special spiritual things happen during the night for you?",
       subtitle = "Error bars are 95% bootstrapped confidence intervals",
       x = "Site", y = "Response")
```


## 18. Do you wake up to pray in the middle of the night? (`slep_ordn18`)

```{r, fig.width = 4, include = T}
d %>%
  mutate(slep_ordn18 = case_when(grepl(",", slep_ordn18) ~ 
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn18)),
         slep_ordn18 = factor(slep_ordn18,
                              levels = c("never", "rarely", "sometimes", "often",
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn18) %>%
  complete(slep_ordn18, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn18, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "18. Do you wake up to pray in the middle of the night? (`slep_ordn18`)",
       x = "Response", y = "Proportion of participants")
```

```{r, fig.width = 4, include = T}
d %>%
  distinct(slep_subj, slep_ctry, slep_ordn18) %>%
  filter(slep_ordn18 != ".") %>%
  ggplot(aes(x = slep_ctry, y = slep_ordn18, color = slep_ctry)) +
  geom_jitter(alpha = 0.25, width = 0.25, height = 0.25) +
  geom_pointrange(data = . %>% 
                    group_by(slep_ctry) %>%
                    mutate(slep_ordn18 = as.numeric(slep_ordn18)) %>%
                    multi_boot_standard(col = "slep_ordn18") %>%
                    ungroup(),
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper), 
                  color = "black") +
  scale_color_brewer(palette = "Dark2", guide = "none") +
  # theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "18. Do you wake up to pray in the middle of the night?",
       subtitle = "Error bars are 95% bootstrapped confidence intervals",
       x = "Site", y = "Response")
```


## 19a. RA judgment for time spent in prayer (`slep_ordn19a`, derived from `slep_ordn19`)

```{r, fig.width = 4, include = T}
d %>%
  distinct(slep_subj, slep_ctry, slep_ordn19a) %>%
  filter(slep_ordn19a != ".") %>%
  ggplot(aes(x = slep_ctry, y = slep_ordn19a, color = slep_ctry)) +
  geom_hline(yintercept = 60, lty = 2) +
  geom_jitter(alpha = 0.25, width = 0.25, height = 0.25) +
  geom_pointrange(data = . %>% 
                    group_by(slep_ctry) %>%
                    mutate(slep_ordn19a = as.numeric(slep_ordn19a)) %>%
                    multi_boot_standard(col = "slep_ordn19a") %>%
                    ungroup(),
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper), 
                  color = "black") +
  scale_color_brewer(palette = "Dark2", guide = "none") +
  scale_y_continuous(trans = "log1p", breaks = seq(0, 1000, 60)) +
  # theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "19a. RA judgment for time spent in prayer (`slep_ordn19a`, derived from `slep_ordn19`)",
       subtitle = "NOTE: Plotted after applying log transformation to highlight differences between sites\nError bars are 95% bootstrapped confidence intervals; dotted lines indicates 1 hour",
       x = "Site", y = "Number of minutes spent in prayer (RA judgment)")
```


## 20. If you do, do you go back to sleep? (`slep_ordn20`)

```{r, fig.width = 4, include = T}
d %>%
  mutate(slep_ordn20 = case_when(grepl(",", slep_ordn20) ~ 
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn20)),
         slep_ordn20 = factor(slep_ordn20,
                              levels = c("never", "rarely", "sometimes", "often",
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn20) %>%
  complete(slep_ordn20, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn20, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "20. If you do, do you go back to sleep? (`slep_ordn20`)",
       x = "Response", y = "Proportion of participants")
```

```{r, fig.width = 4, include = T}
d %>%
  distinct(slep_subj, slep_ctry, slep_ordn20) %>%
  filter(slep_ordn20 != ".") %>%
  ggplot(aes(x = slep_ctry, y = slep_ordn20, color = slep_ctry)) +
  geom_jitter(alpha = 0.25, width = 0.25, height = 0.25) +
  geom_pointrange(data = . %>% 
                    group_by(slep_ctry) %>%
                    mutate(slep_ordn20 = as.numeric(slep_ordn20)) %>%
                    multi_boot_standard(col = "slep_ordn20") %>%
                    ungroup(),
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper), 
                  color = "black") +
  scale_color_brewer(palette = "Dark2", guide = "none") +
  # theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "20. If you do, do you go back to sleep? (`slep_ordn20`)",
       subtitle = "Error bars are 95% bootstrapped confidence intervals",
       x = "Site", y = "Response")
```


## 21. Do you intentionally sleep in any specific positions that have spiritual or health consequences? (`slep_ordn21`)

```{r, fig.width = 4, include = T}
d %>%
  mutate(slep_ordn21 = case_when(grepl(",", slep_ordn21) ~ 
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn21)),
         slep_ordn21 = factor(slep_ordn21,
                              levels = c("never", "rarely", "sometimes", "often",
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn21) %>%
  complete(slep_ordn21, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn21, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "21. Do you intentionally sleep in any specific positions that have spiritual or\nhealth consequences? (`slep_ordn21`)",
       x = "Response", y = "Proportion of participants")
```

```{r, fig.width = 4, include = T}
d %>%
  distinct(slep_subj, slep_ctry, slep_ordn21) %>%
  filter(slep_ordn21 != ".") %>%
  ggplot(aes(x = slep_ctry, y = slep_ordn21, color = slep_ctry)) +
  geom_jitter(alpha = 0.25, width = 0.25, height = 0.25) +
  geom_pointrange(data = . %>% 
                    group_by(slep_ctry) %>%
                    mutate(slep_ordn21 = as.numeric(slep_ordn21)) %>%
                    multi_boot_standard(col = "slep_ordn21") %>%
                    ungroup(),
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper), 
                  color = "black") +
  scale_color_brewer(palette = "Dark2", guide = "none") +
  # theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "21. Do you intentionally sleep in any specific positions that have spiritual or\nhealth consequences? (`slep_ordn21`)",
       subtitle = "Error bars are 95% bootstrapped confidence intervals",
       x = "Site", y = "Response")
```


## 22. Do you interact with God or with spirits in the middle of the night? (`slep_ordn22`)

```{r, fig.width = 4, include = T}
d %>%
  mutate(slep_ordn22 = case_when(grepl(",", slep_ordn22) ~ 
                                   "multiple answers selected",
                                 TRUE ~ as.character(slep_ordn22)),
         slep_ordn22 = factor(slep_ordn22,
                              levels = c("never", "rarely", "sometimes", "often",
                                         "multiple answers selected"))) %>%
  count(slep_ctry, slep_ordn22) %>%
  complete(slep_ordn22, nesting(slep_ctry), fill = list(n = 0)) %>%
  group_by(slep_ctry) %>%
  mutate(prop = n/sum(n, na.rm = T)) %>%
  ggplot(aes(x = slep_ordn22, y = prop, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "identity") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "22. Do you interact with God or with spirits in the middle of the night? (`slep_ordn22`)",
       x = "Response", y = "Proportion of participants")
```

```{r, fig.width = 4, include = T}
d %>%
  distinct(slep_subj, slep_ctry, slep_ordn22) %>%
  filter(slep_ordn22 != ".") %>%
  ggplot(aes(x = slep_ctry, y = slep_ordn22, color = slep_ctry)) +
  geom_jitter(alpha = 0.25, width = 0.25, height = 0.25) +
  geom_pointrange(data = . %>% 
                    group_by(slep_ctry) %>%
                    mutate(slep_ordn22 = as.numeric(slep_ordn22)) %>%
                    multi_boot_standard(col = "slep_ordn22") %>%
                    ungroup(),
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper), 
                  color = "black") +
  scale_color_brewer(palette = "Dark2", guide = "none") +
  # theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "22. Do you interact with God or with spirits in the middle of the night? (`slep_ordn22`)",
       subtitle = "Error bars are 95% bootstrapped confidence intervals",
       x = "Site", y = "Response")
```


## 23.  What wakes you up most at night? (`slep_ordn23`)

```{r, fig.width = 4, include = T}
d %>%
  distinct(slep_ctry, slep_subj, slep_ordn23_Physiological, 
           slep_ordn23_Psychological, slep_ordn23_Dreams,
           slep_ordn23_Sound, slep_ordn23_supernaturalprayer) %>%
  gather(role, response, -c(slep_ctry, slep_subj)) %>%
  mutate(role = recode_factor(role,
                              "slep_ordn23_Physiological" = "physiological",
                              "slep_ordn23_Psychological" = "psychological",
                              "slep_ordn23_Dreams" = "dreams",
                              "slep_ordn23_Sound" = "sounds",
                              "slep_ordn23_supernaturalprayer" = "supernatural"),
         response = case_when(is.na(response) ~ "not selected", TRUE ~ response),
         response = factor(response, levels = c("not selected", "yes"))) %>%
  ggplot(aes(x = role, fill = slep_ctry, alpha = response)) +
  facet_grid(cols = vars(slep_ctry)) +
  geom_bar(stat = "count", position = "fill") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  scale_alpha_manual(values = c(0.1, 1), guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "23. What do you think is the most important role of sleep for you? (`slep_ordn23`)", 
       subtitle = "NOTE: Nikki's codes;\n- Physiological: e.g., body needs, sensory experiences, no reason\n- Psychological: e.g., emotions, plans, thoughts\n- Dreams: e.g., dreams, nightmares, feeling of falling)\n- Sounds: e.g., alarm, people, animals\n- Supernatural: e.g., god, spirit, prayer\nNOTE: many answers not translated!",
       x = "Role", y = "Proportion of participants selecting 'yes'")
```


# "Edge" survey

## Total score (`slep_edge_total`)

```{r, fig.width = 5, include = T}
d %>%
  ggplot(aes(x = slep_edge_total, fill = slep_ctry)) +
  facet_wrap(~ slep_ctry, ncol = 3) +
  geom_density(position = "identity", alpha = 0.5, size = 0.8) +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1),
        legend.position = "top") +
  labs(title = "Edge total score (`slep_edge_total`)", 
       x = "Edge total score (range: 0-60)", 
       y = "Density (~proportion of participants)")
```

```{r, fig.width = 4, include = T}
d %>%
  distinct(slep_subj, slep_ctry, slep_edge_total) %>%
  filter(!is.na(slep_edge_total)) %>%
  ggplot(aes(x = slep_ctry, y = slep_edge_total, color = slep_ctry)) +
  geom_jitter(alpha = 0.25, width = 0.25, height = 0.25) +
  geom_pointrange(data = . %>% 
                    group_by(slep_ctry) %>%
                    multi_boot_standard(col = "slep_edge_total") %>%
                    ungroup(),
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper), 
                  color = "black") +
  scale_color_brewer(palette = "Dark2", guide = "none") +
  scale_y_continuous(breaks = seq(0, 60, 10)) +
  # theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "Edge total score (`slep_edge_total`)",
       subtitle = "Error bars are 95% bootstrapped confidence intervals",
       x = "Site", y = "Edge total score (range: 0-60)")
```


## Individual questions

The "edge" survey consisted of 20 questions, labeled as follows (order may have varied across versions?):

- `slep_edge01`: 11. I've felt an evil presence in the room, but could not see, hear, touch or smell anyone there.
- `slep_edge02`: 12. I've heard someone calling my name
- `slep_edge03`: 13. I've seen a blurry human figure in the room.
- `slep_edge04`: 14.I've had the sense of an invisible presence watching me.
- `slep_edge05`: 15. I've heard the voice of a person I could not identify.
- `slep_edge06`: 16. I've heard human speech which spoke in a garbled, unclear way.
- `slep_edge07`: 17. I've seen the image of a face.
- `slep_edge08`: 18. I've heard the voice of someone familiar to me.
- `slep_edge09`: 19. I've see things or figures floating in my room.
- `slep_edge10`: 20. I've felt the presence of an intruder in my bedroom, though I did not actually see, hear, touch or smell anyone
- `slep_edge11`: 1. I've clearly seen people in my room
- `slep_edge12`: 2. I've heard non-speech sound, such as laughter, music or other noises
- `slep_edge13`: 3. I've seen things in my room other than people
- `slep_edge14`: 4. I've had the feeling of a presence in the room which I felt was aware of me too, but I could not actually see, hear, touch or smell them
- `slep_edge15`: 5. I've heard God (or a spirit) speak
- `slep_edge16`: 6. I've heard God (or a spirit) singing to me.
- `slep_edge17`: 7. I've seen an angel (or a spirit)
- `slep_edge18`: 8. I've seen a ghost
- `slep_edge19`: 9. I've felt the presence of God (or a spirit)
- `slep_edge20`: 10. I have woken up and been unable to move.

```{r}
edge_key <- read_excel("./edge_key.xlsx")
```

```{r, fig.width = 6, include = T}
d %>%
  select(slep_subj, slep_ctry, contains("edge"), -contains("total")) %>%
  distinct() %>%
  gather(question, response, contains("edge")) %>%
  mutate(response = factor(response,
                           levels = c("never", "rarely", 
                                      "occasionally", "frequently"))) %>%
  filter(!is.na(response)) %>%
  ggplot(aes(x = slep_ctry, y = response, color = slep_ctry)) +
  facet_wrap(~ question, ncol = 7) +
  geom_jitter(alpha = 0.05, width = 0.25, height = 0.25) +
  geom_pointrange(data = . %>% group_by(slep_ctry, question) %>%
                    mutate(response = as.numeric(response)) %>%
                    multi_boot_standard(col = "response") %>%
                    ungroup(),
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper),
                  color = "black", fatten = 0.5) +
  geom_text(data = edge_key, 
            aes(x = NULL, y = NULL, color = NULL,
                label = str_wrap(question_text, width = 29)),
            x = 0.75, y = 5.5, color = "black", 
            hjust = 0, vjust = 1, size = 2.5, lineheight = 0.8) +
  scale_color_brewer(palette = "Dark2", guide = "none") +
  scale_y_discrete(expand = expand_scale(add = c(0.6, 1.75))) +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "Responses to 'edge' questions (`slep_edge01`-`slep_edge20`)",
       subtitle = "Error bars are 95% bootstrapped confidence intervals",
       x = "Site", y = "Response")
```

```{r, fig.width = 4, fig.asp = 4, include = T}
d %>%
  select(slep_subj, slep_ctry, contains("edge"), -contains("total")) %>%
  distinct() %>%
  gather(question, response, contains("edge")) %>%
  mutate(response = factor(response,
                           levels = c("never", "rarely", 
                                      "occasionally", "frequently"))) %>%
  ggplot(aes(x = response, fill = slep_ctry)) +
  facet_grid(cols = vars(slep_ctry), rows = vars(question)) +
  geom_bar(stat = "count") +
  scale_fill_brewer(palette = "Dark2", guide = "none") +
  theme(axis.text.x = element_text(angle = 60, hjust = 1, vjust = 1)) +
  labs(title = "Distributions of responses to 'edge' questions (`slep_edge01`-`slep_edge20`)",
       x = "Response", y = "Proportion of participants")
```


